import org.junit.Test

//给定一个整数数组 nums ，找到一个具有最大和的连续子数组（子数组最少包含一个元素），返回其最大和。
//
// 
//
// 示例 1： 
//
// 
//输入：nums = [-2,1,-3,4,-1,2,1,-5,4]
//输出：6
//解释：连续子数组 [4,-1,2,1] 的和最大，为 6 。
// 
//
// 示例 2： 
//
// 
//输入：nums = [1]
//输出：1
// 
//
// 示例 3： 
//
// 
//输入：nums = [0]
//输出：0
// 
//
// 示例 4： 
//
// 
//输入：nums = [-1]
//输出：-1
// 
//
// 示例 5： 
//
// 
//输入：nums = [-100000]
//输出：-100000
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 3 * 104 
// -105 <= nums[i] <= 105 
// 
//
// 
//
// 进阶：如果你已经实现复杂度为 O(n) 的解法，尝试使用更为精妙的 分治法 求解。 
// Related Topics 数组 分治 动态规划 
// 👍 3413 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
class SolutionMaxSubArray {
    @Test
    fun main() {
        println(maxSubArray(intArrayOf(-2, 1, -3, 4, -1, 2, 1, -5, 4)))
        println(maxSubArray(intArrayOf(1)))
        println(maxSubArray(intArrayOf(0)))
        println(maxSubArray(intArrayOf(-1)))
        println(maxSubArray(intArrayOf(-100000)))
    }

    fun maxSubArray(nums: IntArray): Int {
        var max = nums[0]
        var sum = 0
        for (i in 0 until nums.size) {
            sum += nums[i]
            max = max.coerceAtLeast(sum)
            if (sum < 0) {
                sum = 0
            }
        }
        return max
        TODO()
    }
}
//leetcode submit region end(Prohibit modification and deletion)
